-
Notifications
You must be signed in to change notification settings - Fork 3.8k
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Port to master remaining items from 4.4 #11696
Conversation
It seems CI is failing because I missed to update the CMake files. I might have some time to fix that in the following days, but if anybody familiar with CMake wants to help It would be great. I think it is only needed for the new GimbalController class. |
Thanks @Davidsastresas. Sounds like we should do a v4.4.1 release soon. |
Great to see this! of course I'll help with testing and if we want to do that 4.4.1 release then I'll help organise that like last time |
I suppose we don't need QGeoTiledMapReplyQGC::setIgnoreSSLErrorsIfNeeded in Qt6 since it already uses OpenSSL3, but it doesn't hurt to have it either |
Good catch! At first I thought the same, but then I realized it is useful too for the other way around, for Qt6 in systems that have OpenSSL1 instead. I think it doesn't hurt either, so I would vote for leaving it there. Thanks for the review! |
@Davidsastresas Fixed CMake |
Amazing, thank you very much! Let's give it a few days in case Julian and Randy come up with some modification needed before merging. I will remove the draft label too. Thank you! |
I tried to test this today on my Windows machine and it wouldn't even start. I used the installer found here. I suspect that the issue is not actually related to this PR so I tried to install the "Daily Build" but was not able to find an installer. The link on the Daily Builds page seems broken (click here to see what I mean) |
Sorry to hear that @rmackay9, if you had your previous build environment setup for QGC 4.4, for master you need qt6, and I am not sure if for windows you need different visual studio toolchain too. There are lots of changes on the build setup right now for QGC 4.4 vs master. The builds corresponding to this PR should be here ( I found them searching manually in actions ): Let me know if that fixes the situation for the moment! EDIT - I see you used the build I recommended above, sorry I don't know why I thought you were trying to build from source. How was it not even starting, did it report something or any kind of error popup? @HTRamsey, do you know if master is supposed to be working fine in windows? Thanks! |
Oh you'll have to try again on the latest build because of this #11678, it works fine now. |
Hi @HTRamsey, Is there a link to a Windows installer for latest? I can't find one that works (see my comment above). I wonder if this PR should be rebased on master to pickup PR 11678? |
You can always just grab it from the latest run. But yeah I guess the daily windows link needs to be updated. Also @Davidsastresas you said you found those links manually from actions, if I'm understanding you correctly just FYI you can also just click details on the builds results below where it says All checks have passed. Capitals shouldn't matter in a URL but I noticed the installer has an upper case 'i' while the link & docs have it as lower case. Could that be why the download isn't working? |
Thanks for that. So the daily build using this installer does work and I think this means that this PR does not but hopefully that is just because it needs to be rebased (I'm guessing of course) |
@Davidsastresas a followup to my QGeoMapReplyQGC comment, you can just use QGCFileDownload::setIgnoreSSLErrorsIfNeeded which is the exact same function. |
f143d12
to
32d618a
Compare
@HTRamsey For some reason doing that I can only see the job, but not the artifact to download! Does it work for you to download the artifact too? I am using google chrome in case that matters. Thanks for fixing build for Windows. I haven't had the chance to build because I need to setup cmake, I was still using qmake, it is probably not a big deal but I need to spare an hour or two to understand everything for the next time. I rebased to master. @rmackay9 after it finishes it should be ready for you to test. Thanks! |
@HTRamsey Please note the branch is in mavlink repo, so you can directly push commits to it. Please feel free to change that if you see fit. As it is now it works for me on a machine with OpenSSL 1 on Ubuntu 20.04. Thanks! |
32d618a
to
d3c3f30
Compare
@julianoes for awareness, I just pushed here your commits from this PR #11706 So hopefully we can keep master updated with what we are doing in QGC 4. Thanks! |
@Davidsastresas after clicking details you have to click Summary at the top left |
No way.... I've been for ages thinking it was a github bug. Thank you for enlightening me! :) |
I tested this today on my windows PC and it seems to work fine with some issues found which I think are also in QGC Daily. I connected my desktop CubeRed + SiyiA8 to my PC via USB and confirmed the following worked
By the way, not related directly to this testing but this gave me the opportunity to test the camera controls (FYI @DonLakeFlyer):
Also not related to this PR but it seems that QGC Daily is not proactively requesting data from the autopilot. It seems to be passively waiting for the drone to start sending mavlink messages. This seems like a change in behaviour vs QGC4.4. I guess it is intentional? BTW, I think that AP obeys the mavlink spec and we've documented here on this AP wiki page how GCSs, companion computers can request data be sent by the autopilot which includes three basic methods:
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
I've done my testing and it seems to work just like in QGC4.4
Thanks again for this great enhancement!
Thanks @rmackay9 for the confirmation. I will hold on a couple days more, as we found a bug that was preventing AP to work correctly on that "point home" action, so next week I will add that and merge this if @julianoes is alright with the changes. Regarding the default rates, indeed the default behavior changed vs 4.4, but you can change the setting so QGC asks the rates to the autopilot, here: The difference is that this setting was enabled by default in 4.4, but it is not by default in master. Is this super problematic for AP? I thought by default in AP we had some kind of default for those SRX parameters. Let me know your thoughts! |
@Davidsastresas ok, so we should disable it again in v4.4? PX4 has some default rates. AP requires it to be configured, right? |
Hi @Davidsastresas, Thanks for the feedback on the rates. I think it will be a large problem for AP copter users. Copter does not set the stream rates by default (Plane and Rover do). So if possible I think for AP users QGC should ask for the streams it wants by default |
…y Alex de la Torre Co-authored-by: davidsastresas <[email protected]> Co-authored-by: alexdelatorre <[email protected]>
before this commit it was ocupying only the missionitemindex label, which is very small. Now it takes into account the are with the label as well
this allows for ROI commanded elsewhere than clicking on map ( like gimbal panel point home action ) to show the ROI indicator on map
Instead of setting manually the roilocationitem coordinate in flyviewmap.qml, we rely instead on the new signal from vehicle. This way, changes in roi in other parts of the app than map clicks, like gimbal controls point home, will make the roi indicator appear
…cking feature after rebase
… tests: RequestMessageTest implementation collides with how gimbal controller works. Gimbal controller will request some messages when hearbeat is received, to try to discover new gimbals, and it messes with this particular test, so this way we can disable gimbal manager just for this test
As it also sends request messages and it collides with the requests of this test
gimbal controller sends some message requests when receiving a hearbeat, and the cmd results collide with this test, so we filter out MAV_CMD_REQUEST_MESSAGE from gimbal controller
Could interfere with parameter download on Herelink slower link
There was no wait between such requests, and Ardupilot was failing to detect the handshake some times
The used commands like REQUEST_CAMERA_SETTINGS and REQUEST_CAMERA_INFORMATION are deprecated. Therefore, we should gradually try to move to the new REQUEST_MESSAGE commands. This commit does so by sending REQUEST_MESSAGE by default but falling back to the previous commands on the second try and every other retry after that.
By querying autopilot for the CAMERA_INFORMATION message, we allow an autopilot to be a proxy for a MAVLink or non-MAVLink camera. The idea is similar to a gimbal manager implemented by an autopilot.
Since we no longer request cameras to have specific camera component IDs but allow the autopilot to "be" a camera as well, we need to adjust the unit tests to account for that.
This fixes getting the video stream.
This made sense when we were not taking compid autopilot into account, but now it will log this every vehicle connection if it isn't emulating a mavlink camera
Otherwise, we potentially work with garbage.
This changes how the found gimbals are referenced. Instead of only using the gimbal device ID for the gimbal map, we now also use the gimbal manager compid. This assumes that it is valid to have more than one gimbal manager with non-MAVLink gimbals attached, which means the gimbal_device_id would clash in that case, e.g. both would be 1. Therefore, we use the gimbal manager compid as well as the associated gimbal_device_id as the map key.
We should use the new yaw value, not the previous one when calculating the missing frame.
We shouldn't just send the commands to the vehicle because the gimbal manager might be implemented on any component, not just the autopilot.
28ee027
to
af06849
Compare
Thanks @DonLakeFlyer, it seems @HTRamsey did the rebase yesterday ( thank you! ) and everything was clear to merge, so I went ahead. As far as I know, this should leave master with all the features 4.4 currently has. We can follow on that other thread about the default stream rates issue later. thank you everybody! |
I downloaded the newest version QGC on github, and I Build it with the QT Creator version 14.0.2 , QT 6.7.3 and Visual Studio 2022. When I changed the video input method to RTSP, I received the error : VideoReceiverLog: Failed and VideoReceiverLog: Stop Called on empty URI. I had search for the information about the error and I found that may be the problem of QT5 -> QT6. Can anyone help me about this problem. |
This PR brings to master some items that were pushed to 4.4 but were still missing in master. It includes:
New gimbal controls: #11264
Some aditional fixes and improvements: #11276
Some extra fixes: 4fc99bc 748d185 5218925 69b3ec2
I only tested the changes related to gimbal controls, and they seem to be working the same as in 4.4.
@julianoes, I realized your fixes to camera manager were not present in master, so I brought them from 4.4 too. I think it should be fine, but It would be good if you want to double check. Thanks!
@rmackay9, Even though I tested in SITL the gimbal controls it would be good if you can double check. Thanks!
The following is a list of the commits that were meant to be brought to master, indicating the ones present here as "done" and the ones not brought to this PR indicated: